# 32-Bit RISC Processor Pipeline

# **Instruction Encoding Scheme**

- K.Kishorereddy

## **Encoding Scheme:**

| B31 B30 B29 B28 B27 B26 | B25 B24 B23 B22 B21 | B20 B19 B18 B17 B16 | B15 B14 B13 B12 B13 | B10 B9 B | 8 B7 | B6 B5 | 5 B4 | ВЗ | В2 | В1 | во |
|-------------------------|---------------------|---------------------|---------------------|----------|------|-------|------|----|----|----|----|
| < Op Code>              | Destination         | Source Reg1         | Source Reg 2        |          |      |       |      |    |    |    |    |
|                         | Reg                 |                     | < Immediate Value   |          |      |       |      |    | >  |    |    |

#### Note:

• Please refer to the Example section for more specifics about encoding of each instruction.

## **Assembler Tables:**

#### Instructions:

| Instruction | Op-Code |  |  |
|-------------|---------|--|--|
| MOV         | XX0000  |  |  |
| MVI         | XX0001  |  |  |
| ADD         | XX0010  |  |  |
| ADI         | XX0011  |  |  |
| SUB         | XX0100  |  |  |
| SUI         | XX0101  |  |  |
| AND         | XX0110  |  |  |
| ANI         | XX0111  |  |  |
| OR          | XX1000  |  |  |
| ORI         | XX1001  |  |  |
| LOAD        | XX1010  |  |  |
| STORE       | XX1011  |  |  |
| HLT         | XX11XX  |  |  |

### Note:

- Op-Codes of any of the Instructions require only 4-bit at maximum but to maintain the instruction size as 32-bits the Op-Code was made to be 6 bits.
- And the first two bits can be anything (hence the XX s in the above table) because only the last 4 bits of the Op-Code are considered for identifying the instruction.
- To use all the 16 numbers for instruction HLT was assigned 4 Op-codes (XX1100, XX1101, XX1110, XX111). Using anyone of those implies HLT instruction.

### Registers:

Total of 32 registers are provided. And are addressed as R0, R1, ..., R31.

| Register | Encoding | Register | Encoding |
|----------|----------|----------|----------|
| RO       | 00000    | R16      | 10000    |
| R1       | 00001    | R17      | 10001    |
| R2       | 00010    | R18      | 10010    |
| R3       | 00011    | R19      | 10011    |
| R4       | 00100    | R20      | 10100    |
| R5       | 00101    | R21      | 10101    |
| R6       | 00110    | R22      | 10110    |
| R7       | 00111    | R23      | 10111    |
| R8       | 01000    | R24      | 11000    |
| R9       | 01001    | R25      | 11001    |
| R10      | 01010    | R26      | 11010    |
| R11      | 01011    | R27      | 11011    |
| R12      | 01100    | R28      | 11100    |
| R13      | 01101    | R29      | 11101    |
| R14      | 01110    | R30      | 11110    |
| R15      | 01111    | R31      | 11111    |

### **Example Instructions:**

The X s in the Binary format of the instruction imply that those bits does not affect the instruction. For simplicity they're taken as zeroes for generating hex format of the instruction.

- MOV R1, R2
  - o R1 <- [R2]

  - o 00220000h
- MVI R1, 1111h
  - o R1 <- 00001111h
  - o XX 0001 00001 XXXXX 000100010001
  - o 04201111h
- ADD R1, R2, R3
  - o R1 <- [R2] + [R3]
  - o XX 0010 00001 00010 00011XXXXXXXXXXX
  - o 08221800h
- ADI R1, R2, 1111h
  - o R1 <- [R2] + 00001111h
  - O XX 0011 00001 00010 000100010001
  - o 0c221111h

- SUB R1, R2, R3
  - $\circ$  R1 <- [R2] [R3]
  - o XX 0100 00001 00010 00011XXXXXXXXXXX
  - o 10221800h
- SUI R1, R2, 1111h
  - R1 <- [R2] 00001111h
  - O XX 0101 00001 00010 000100010001
  - o 14221111h
- AND R1, R2, R3
  - o R1 <- [R2] AND [R3]
  - o XX 0110 00001 00010 00011XXXXXXXXXXXX
  - o 18221800h
- ANI R1, R2, 1111h
  - o R1 <- [R2] AND 00001111h
  - O XX 0111 00001 00010 000100010001
  - o 1c221111h
- OR R1, R2, R3
  - o R1 <- [R2] OR [R3]
  - O XX 1000 00001 00010 00011XXXXXXXXXXXX
  - o 20221800h
- ORI R1, R2, 1111h
  - o R1 <- [R2] OR 00001111h
  - O XX 1001 00001 00010 000100010001
  - o 24221111h
- LOAD R1, 1111h(R2)
  - o R1 <- [[R2]+00001111h]
  - O XX 1010 00001 00010 000100010001
  - o 28221111h
- STORE R1, 1111h(R2)
  - o [R2]+00001111h <- [R1]
  - O XX 1011 00001 00010 000100010001
  - o 2c221111h
- HLT

  - o 30000000h